gusucode.com > 现代通信系统——使用MATLAB(+全部程序) > 现代通信系统——使用MATLAB(+全部程序)/现代通信系统——使用MATLAB(+全部程序)/Matlab 程序/Chapter3/ip_03_02.m

    % MATLAB script for Illustrative Problem 3.2.
% Matlab demonstration script for DSB-AM modulation. The message signal
% is m(t)=sinc(100t). 
echo on 
t0=.2;                      % signal duration
ts=0.001;                   % sampling interval
fc=250;                     % carrier frequency
snr=20;                     % SNR in dB (logarithmic)
fs=1/ts;                    % sampling frequency
df=0.3;                                         % required freq. resolution
t=[-t0/2:ts:t0/2];              % time vector
snr_lin=10^(snr/10);                % linear SNR
m=sinc(100*t);                  % the message signal
c=cos(2*pi*fc.*t);              % the carrier signal
u=m.*c;                     % the DSB-AM modulated signal
[M,m,df1]=fftseq(m,ts,df);                      % Fourier transform
M=M/fs;                                         % scaling
[U,u,df1]=fftseq(u,ts,df);                      % Fourier transform
U=U/fs;                                         % scaling
f=[0:df1:df1*(length(m)-1)]-fs/2;               % frequency vector
signal_power=spower(u(1:length(t)));            % Compute modulated signal power.
noise_power=signal_power/snr_lin;       % Compute noise power.
noise_std=sqrt(noise_power);            % Compute noise standard deviation.
noise=noise_std*randn(1,length(u));             % Generate noise sequence.
r=u+noise;                  % add noise to the modulated signal
[R,r,df1]=fftseq(r,ts,df);                      % Fourier transform
R=R/fs;                                         % scaling
pause  % Press a key to show the modulated signal power.
signal_power
pause  %Press any key to see a plot of the message.
clf
subplot(2,2,1)
plot(t,m(1:length(t)))
xlabel('Time')
title('The message signal')   
pause % Press any key to see a plot of the carrier.
subplot(2,2,2)
plot(t,c(1:length(t)))
xlabel('Time')
title('The carrier') 
pause  % Press any key to see a plot of the modulated signal.
subplot(2,2,3)
plot(t,u(1:length(t)))
xlabel('Time')
title('The modulated signal') 
pause   % Press any key to see a plot  of the magnitude of the message and the
    % modulated signal in the frequency domain.
subplot(2,1,1)
plot(f,abs(fftshift(M)))
xlabel('Frequency')
title('Spectrum of the message signal')
subplot(2,1,2)
plot(f,abs(fftshift(U)))
title('Spectrum of the modulated signal')
xlabel('Frequency') 
pause  % Press a key to see a noise sample.
subplot(2,1,1)
plot(t,noise(1:length(t)))
title('Noise sample') 
xlabel('Time')
pause  % Press a key to see the modulated signal and noise.
subplot(2,1,2)
plot(t,r(1:length(t)))
title('Signal and noise')
xlabel('Time')
pause  % Press a key to see the modulated signal and noise in freq. domain.
subplot(2,1,1)
plot(f,abs(fftshift(U)))
title('Signal spectrum')
xlabel('Frequency')
subplot(2,1,2) 
plot(f,abs(fftshift(R))) 
title('Signal and noise spectrum')
xlabel('Frequency')